123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201 |
- "use client";
- import { GroupType, PrizeTypes } from "@/api/home";
- import Box from "@/components/Box";
- import { useRouter } from "@/i18n/routing";
- import { useSystemStore } from "@/stores/useSystemStore";
- import { Toast } from "antd-mobile";
- import clsx from "clsx";
- import { useTranslations } from "next-intl";
- import { FC, useState } from "react";
- import { Swiper, SwiperSlide } from "swiper/react";
- import HomeGames from "./HomeGames";
- // import HomePrize from "./HomePrize";
- const buttonGroup = [
- {
- icon: "qianbao3",
- category_name: "sixth",
- isHot: false,
- url: "/freeGames",
- locale: true,
- lock: false,
- isAnimation: true,
- image: "/home/free.png",
- },
- {
- icon: "qianbao3",
- category_name: "seventh",
- isHot: false,
- url: "/replayGames",
- locale: true,
- lock: false,
- image: "/home/replay.png",
- },
- {
- icon: "liwulipinjiangpin",
- category_name: "first",
- isHot: true,
- url: "/promo",
- locale: true,
- lock: false,
- image: "/home/promoto.png",
- },
- // {
- // icon: "pro-youxi1",
- // category_name: "second",
- // isHot: false,
- // url: "/gameList/110",
- // locale: true,
- // lock: true,
- // },
- // {
- // icon: "huodongyule",
- // category_name: "third",
- // isHot: false,
- // url: "/sports",
- // locale: true,
- // lock: false,
- // },
- {
- icon: "shipin",
- category_name: "fourth",
- isHot: false,
- url: "/gameList?gameListFlag=10&type=1&bet_type=1&name=live",
- locale: true,
- lock: false,
- image: "/home/live.png",
- },
- {
- icon: "yingyong",
- category_name: "Fifth",
- isHot: false,
- url: "/download",
- locale: true,
- lock: false,
- image: "/home/app.png",
- },
- ] as const;
- type TabItemType = (typeof buttonGroup)[number] & GroupType;
- const TabItem = ({
- item,
- active,
- onClick,
- }: {
- item: TabItemType;
- active?: boolean;
- onClick?: (item: TabItemType) => void;
- }) => {
- const t = useTranslations("ButtonGroup");
- const router = useRouter();
- const handler = (item: TabItemType) => {
- if (!item.locale) {
- onClick && onClick(item);
- return;
- }
- if (item.lock) {
- Toast.show("It is under development.");
- } else {
- router.push(item.url);
- }
- };
- const cls = clsx("pro-iconfont text-[.34rem]", `pro-${item.icon}`);
- // const cls2 = clsx("iconfont text-[.34rem]", `icon-${item.icon}`);
- const rootCls = clsx(
- "relative flex flex-1 cursor-pointer items-center flex-col",
- active ? "text-[#d0f5fb]" : "text-[#d0f5fb]"
- );
- return (
- <div className={rootCls} onClick={() => handler(item)}>
- <div className="flex h-[.55rem] items-end justify-center">
- {!item.image && <span className={cls}></span>}
- {item.image && (
- <img
- src={item.image}
- width={45}
- height={55}
- alt={item.url}
- className={clsx(item.isAnimation ? "animate-slow-bounce" : "")}
- ></img>
- )}
- </div>
- <span className={"break-word truncate whitespace-normal text-center text-[0.13rem]"}>
- {item.locale ? t(item.category_name) : item.category_name}
- </span>
- {/* {item.isHot && (
- <img
- className={"absolute -top-[0.12rem] right-0 h-[0.21rem] w-[0.21rem]"}
- src=""
- alt=""
- />
- )} */}
- </div>
- );
- };
- interface Props {
- tabs: GroupType[];
- prize?: PrizeTypes[];
- }
- const Tabs: FC<Props> = (props) => {
- const { tabs, prize } = props;
- const { show_again_game, show_free_game } = useSystemStore((state) => {
- return {
- show_again_game: state.show_again_game,
- show_free_game: state.show_free_game,
- };
- });
- const newButtonGroup = buttonGroup.filter((item: any) => {
- if (item.url === "/freeGames" && show_free_game !== 1) {
- return false;
- }
- if (item.url === "/replayGames" && show_again_game !== 1) {
- return false;
- }
- return true;
- });
- const tabData = [...tabs, ...newButtonGroup];
- const [active, setActive] = useState<number>(0);
- const router = useRouter();
- const selectHandler = (item: TabItemType, index: number) => {
- if (item.bet_type === 2 || item.bet_type === 3) {
- router.push(
- `/gameList/?gameListFlag=${item.category[0].jump_id}&type=1&bet_type=${item.bet_type}`
- );
- return;
- }
- setActive(index);
- };
- const groupGames = tabs[active]?.category;
- return (
- <>
- <Box pt={false} className="px-[.3rem]">
- <Swiper slidesPerView={5} centeredSlides={true} centeredSlidesBounds>
- {tabData?.map((group, index) => (
- <SwiperSlide key={index}>
- <TabItem
- item={group as TabItemType}
- active={index === active}
- onClick={(event) => selectHandler(event, index)}
- ></TabItem>
- </SwiperSlide>
- ))}
- </Swiper>
- </Box>
- {/* <HomePrize data={prize}></HomePrize> */}
- <HomeGames groupGames={groupGames} />
- </>
- );
- };
- export default Tabs;
|